// 蜂窝蜜造平台生成代码，如手工更改，请添加到 .beeignore 忽略生成

package com.fowo.api.model.parilist;

import com.fowo.api.common.annotaion.DataObjectType;
import com.fowo.api.common.meta.MetaDataObject;
import com.fowo.api.common.meta.MetaDataObjects;
import com.fowo.api.common.model.PageSearch;
import com.fowo.api.common.mybatis.helper.PageSearchHelper;
import com.fowo.api.common.util.ListUtils;
import com.fowo.api.entity.Parilist;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import lombok.Getter;
import lombok.Setter;
import org.springframework.format.annotation.DateTimeFormat;

@DataObjectType(Parilist.class)
@Setter
@Getter
public class ParilistSearchParamPo extends PageSearch {

  private static MetaDataObject metaDataObject;

  @Override
  public void applySqlSegments() {
    if (metaDataObject == null) {
      metaDataObject =
        ListUtils.find(
          MetaDataObjects.getObjects(),
          o -> "Parilist".equals(o.getName())
        );
    }
    PageSearchHelper.fillSqlSegments(this, metaDataObject);
  }

  @Override
  public void initFinal() {
    super.initFinal();
    applySqlSegments();
  }

  /**
   * 获取关联字段的查询表别名信息
   */
  @Override
  public Map<String, String> getJoinFieldTableAliasMap() {
    Map<String, String> map = new HashMap<>();
    map.put("shopId", "si");
    map.put("productId", "p");
    return map;
  }

  @Override
  public Map<String, OptionalJoinField> getOptionalJoinFields() {
    Map<String, OptionalJoinField> map = new HashMap<>();

    return map;
  }

  /**
   * 指定使用特定的视图过滤条件
   * <p>
   * 有效值包括：Parilist/Unpaired, Parilist/Paired
   * </p>
   */
  private String byViewName;

  /**
   * 编号
   */
  private Long id;

  /**
   * 最小编号
   */
  private Long idMin;

  /**
   * 最大编号
   */
  private Long idMax;

  /**
   * 编号 比较(eq)
   */
  private Long idEq;
  /**
   * 编号 比较(neq)
   */
  private Long idNeq;
  /**
   * 编号 比较(gt)
   */
  private Long idGt;
  /**
   * 编号 比较(gte)
   */
  private Long idGte;
  /**
   * 编号 比较(lt)
   */
  private Long idLt;
  /**
   * 编号 比较(lte)
   */
  private Long idLte;
  /**
   * 编号 比较(contains)
   */
  private Long idContains;
  /**
   * 编号 比较(notcontains)
   */
  private Long idNotcontains;
  /**
   * 编号 比较(startswith)
   */
  private Long idStartswith;
  /**
   * 编号 比较(endswith)
   */
  private Long idEndswith;
  /**
   * 编号 比较(isnull)
   */
  private Boolean idIsnull;
  /**
   * 编号 比较(isnotnull)
   */
  private Boolean idIsnotnull;

  /**
   * MSKU(模糊搜索)
   */
  private String msku;

  /**
   * MSKU 比较(eq)
   */
  private String mskuEq;
  /**
   * MSKU 比较(neq)
   */
  private String mskuNeq;
  /**
   * MSKU 比较(gt)
   */
  private String mskuGt;
  /**
   * MSKU 比较(gte)
   */
  private String mskuGte;
  /**
   * MSKU 比较(lt)
   */
  private String mskuLt;
  /**
   * MSKU 比较(lte)
   */
  private String mskuLte;
  /**
   * MSKU 比较(contains)
   */
  private String mskuContains;
  /**
   * MSKU 比较(notcontains)
   */
  private String mskuNotcontains;
  /**
   * MSKU 比较(startswith)
   */
  private String mskuStartswith;
  /**
   * MSKU 比较(endswith)
   */
  private String mskuEndswith;
  /**
   * MSKU 比较(isnull)
   */
  private Boolean mskuIsnull;
  /**
   * MSKU 比较(isnotnull)
   */
  private Boolean mskuIsnotnull;

  /**
   * MSKU(精确搜索)
   */
  private List<String> mskuInList;

  /**
   * 店铺
   */
  private Long shopId;

  /**
   * 店铺 比较(eq)
   */
  private Long shopIdEq;
  /**
   * 店铺 比较(neq)
   */
  private Long shopIdNeq;
  /**
   * 店铺 比较(gt)
   */
  private Long shopIdGt;
  /**
   * 店铺 比较(gte)
   */
  private Long shopIdGte;
  /**
   * 店铺 比较(lt)
   */
  private Long shopIdLt;
  /**
   * 店铺 比较(lte)
   */
  private Long shopIdLte;
  /**
   * 店铺 比较(contains)
   */
  private Long shopIdContains;
  /**
   * 店铺 比较(notcontains)
   */
  private Long shopIdNotcontains;
  /**
   * 店铺 比较(startswith)
   */
  private Long shopIdStartswith;
  /**
   * 店铺 比较(endswith)
   */
  private Long shopIdEndswith;
  /**
   * 店铺 比较(isnull)
   */
  private Boolean shopIdIsnull;
  /**
   * 店铺 比较(isnotnull)
   */
  private Boolean shopIdIsnotnull;
  /**
   * 店铺的名称 比较(eq)
   */
  private String shopIdShopNameEq;
  /**
   * 店铺的名称 比较(neq)
   */
  private String shopIdShopNameNeq;
  /**
   * 店铺的名称 比较(gt)
   */
  private String shopIdShopNameGt;
  /**
   * 店铺的名称 比较(gte)
   */
  private String shopIdShopNameGte;
  /**
   * 店铺的名称 比较(lt)
   */
  private String shopIdShopNameLt;
  /**
   * 店铺的名称 比较(lte)
   */
  private String shopIdShopNameLte;
  /**
   * 店铺的名称 比较(contains)
   */
  private String shopIdShopNameContains;
  /**
   * 店铺的名称 比较(notcontains)
   */
  private String shopIdShopNameNotcontains;
  /**
   * 店铺的名称 比较(startswith)
   */
  private String shopIdShopNameStartswith;
  /**
   * 店铺的名称 比较(endswith)
   */
  private String shopIdShopNameEndswith;
  /**
   * 店铺的名称 比较(isnull)
   */
  private Boolean shopIdShopNameIsnull;
  /**
   * 店铺的名称 比较(isnotnull)
   */
  private Boolean shopIdShopNameIsnotnull;

  /**
   * 店铺(范围搜索)
   */
  private List<Long> shopIdInList;

  /**
   * 是否有 图片
   */
  private Boolean img;

  /**
   * 产品名称(模糊搜索)
   */
  private String productName;

  /**
   * 产品名称 比较(eq)
   */
  private String productNameEq;
  /**
   * 产品名称 比较(neq)
   */
  private String productNameNeq;
  /**
   * 产品名称 比较(gt)
   */
  private String productNameGt;
  /**
   * 产品名称 比较(gte)
   */
  private String productNameGte;
  /**
   * 产品名称 比较(lt)
   */
  private String productNameLt;
  /**
   * 产品名称 比较(lte)
   */
  private String productNameLte;
  /**
   * 产品名称 比较(contains)
   */
  private String productNameContains;
  /**
   * 产品名称 比较(notcontains)
   */
  private String productNameNotcontains;
  /**
   * 产品名称 比较(startswith)
   */
  private String productNameStartswith;
  /**
   * 产品名称 比较(endswith)
   */
  private String productNameEndswith;
  /**
   * 产品名称 比较(isnull)
   */
  private Boolean productNameIsnull;
  /**
   * 产品名称 比较(isnotnull)
   */
  private Boolean productNameIsnotnull;

  /**
   * 产品名称(精确搜索)
   */
  private List<String> productNameInList;

  /**
   * sku(模糊搜索)
   */
  private String sku;

  /**
   * sku 比较(eq)
   */
  private String skuEq;
  /**
   * sku 比较(neq)
   */
  private String skuNeq;
  /**
   * sku 比较(gt)
   */
  private String skuGt;
  /**
   * sku 比较(gte)
   */
  private String skuGte;
  /**
   * sku 比较(lt)
   */
  private String skuLt;
  /**
   * sku 比较(lte)
   */
  private String skuLte;
  /**
   * sku 比较(contains)
   */
  private String skuContains;
  /**
   * sku 比较(notcontains)
   */
  private String skuNotcontains;
  /**
   * sku 比较(startswith)
   */
  private String skuStartswith;
  /**
   * sku 比较(endswith)
   */
  private String skuEndswith;
  /**
   * sku 比较(isnull)
   */
  private Boolean skuIsnull;
  /**
   * sku 比较(isnotnull)
   */
  private Boolean skuIsnotnull;

  /**
   * sku(精确搜索)
   */
  private List<String> skuInList;

  /**
   * 平台
   */
  private String platforms;

  /**
   * 平台 比较(eq)
   */
  private String platformsEq;
  /**
   * 平台 比较(neq)
   */
  private String platformsNeq;
  /**
   * 平台 比较(gt)
   */
  private String platformsGt;
  /**
   * 平台 比较(gte)
   */
  private String platformsGte;
  /**
   * 平台 比较(lt)
   */
  private String platformsLt;
  /**
   * 平台 比较(lte)
   */
  private String platformsLte;
  /**
   * 平台 比较(contains)
   */
  private String platformsContains;
  /**
   * 平台 比较(notcontains)
   */
  private String platformsNotcontains;
  /**
   * 平台 比较(startswith)
   */
  private String platformsStartswith;
  /**
   * 平台 比较(endswith)
   */
  private String platformsEndswith;
  /**
   * 平台 比较(isnull)
   */
  private Boolean platformsIsnull;
  /**
   * 平台 比较(isnotnull)
   */
  private Boolean platformsIsnotnull;

  /**
   * 平台(精确搜索)
   */
  private List<String> platformsInList;

  /**
   * 最早创建时间
   */
  @DateTimeFormat(pattern = "yyyy-MM-dd")
  private Date createTimeStart;

  /**
   * 最晚创建时间
   */
  @DateTimeFormat(pattern = "yyyy-MM-dd")
  private Date createTimeEnd;

  /**
   * 创建时间 比较(eq)
   */
  private Date createTimeEq;
  /**
   * 创建时间 比较(neq)
   */
  private Date createTimeNeq;
  /**
   * 创建时间 比较(gt)
   */
  private Date createTimeGt;
  /**
   * 创建时间 比较(gte)
   */
  private Date createTimeGte;
  /**
   * 创建时间 比较(lt)
   */
  private Date createTimeLt;
  /**
   * 创建时间 比较(lte)
   */
  private Date createTimeLte;
  /**
   * 创建时间 比较(contains)
   */
  private Date createTimeContains;
  /**
   * 创建时间 比较(notcontains)
   */
  private Date createTimeNotcontains;
  /**
   * 创建时间 比较(startswith)
   */
  private Date createTimeStartswith;
  /**
   * 创建时间 比较(endswith)
   */
  private Date createTimeEndswith;
  /**
   * 创建时间 比较(isnull)
   */
  private Boolean createTimeIsnull;
  /**
   * 创建时间 比较(isnotnull)
   */
  private Boolean createTimeIsnotnull;

  /**
   * 创建人
   */
  private Long createUser;

  /**
   * 最小创建人
   */
  private Long createUserMin;

  /**
   * 最大创建人
   */
  private Long createUserMax;

  /**
   * 创建人 比较(eq)
   */
  private Long createUserEq;
  /**
   * 创建人 比较(neq)
   */
  private Long createUserNeq;
  /**
   * 创建人 比较(gt)
   */
  private Long createUserGt;
  /**
   * 创建人 比较(gte)
   */
  private Long createUserGte;
  /**
   * 创建人 比较(lt)
   */
  private Long createUserLt;
  /**
   * 创建人 比较(lte)
   */
  private Long createUserLte;
  /**
   * 创建人 比较(contains)
   */
  private Long createUserContains;
  /**
   * 创建人 比较(notcontains)
   */
  private Long createUserNotcontains;
  /**
   * 创建人 比较(startswith)
   */
  private Long createUserStartswith;
  /**
   * 创建人 比较(endswith)
   */
  private Long createUserEndswith;
  /**
   * 创建人 比较(isnull)
   */
  private Boolean createUserIsnull;
  /**
   * 创建人 比较(isnotnull)
   */
  private Boolean createUserIsnotnull;

  /**
   * 最早更新时间
   */
  @DateTimeFormat(pattern = "yyyy-MM-dd")
  private Date lastUpdateTimeStart;

  /**
   * 最晚更新时间
   */
  @DateTimeFormat(pattern = "yyyy-MM-dd")
  private Date lastUpdateTimeEnd;

  /**
   * 更新时间 比较(eq)
   */
  private Date lastUpdateTimeEq;
  /**
   * 更新时间 比较(neq)
   */
  private Date lastUpdateTimeNeq;
  /**
   * 更新时间 比较(gt)
   */
  private Date lastUpdateTimeGt;
  /**
   * 更新时间 比较(gte)
   */
  private Date lastUpdateTimeGte;
  /**
   * 更新时间 比较(lt)
   */
  private Date lastUpdateTimeLt;
  /**
   * 更新时间 比较(lte)
   */
  private Date lastUpdateTimeLte;
  /**
   * 更新时间 比较(contains)
   */
  private Date lastUpdateTimeContains;
  /**
   * 更新时间 比较(notcontains)
   */
  private Date lastUpdateTimeNotcontains;
  /**
   * 更新时间 比较(startswith)
   */
  private Date lastUpdateTimeStartswith;
  /**
   * 更新时间 比较(endswith)
   */
  private Date lastUpdateTimeEndswith;
  /**
   * 更新时间 比较(isnull)
   */
  private Boolean lastUpdateTimeIsnull;
  /**
   * 更新时间 比较(isnotnull)
   */
  private Boolean lastUpdateTimeIsnotnull;

  /**
   * 更新人
   */
  private Long lastUpdateUser;

  /**
   * 最小更新人
   */
  private Long lastUpdateUserMin;

  /**
   * 最大更新人
   */
  private Long lastUpdateUserMax;

  /**
   * 更新人 比较(eq)
   */
  private Long lastUpdateUserEq;
  /**
   * 更新人 比较(neq)
   */
  private Long lastUpdateUserNeq;
  /**
   * 更新人 比较(gt)
   */
  private Long lastUpdateUserGt;
  /**
   * 更新人 比较(gte)
   */
  private Long lastUpdateUserGte;
  /**
   * 更新人 比较(lt)
   */
  private Long lastUpdateUserLt;
  /**
   * 更新人 比较(lte)
   */
  private Long lastUpdateUserLte;
  /**
   * 更新人 比较(contains)
   */
  private Long lastUpdateUserContains;
  /**
   * 更新人 比较(notcontains)
   */
  private Long lastUpdateUserNotcontains;
  /**
   * 更新人 比较(startswith)
   */
  private Long lastUpdateUserStartswith;
  /**
   * 更新人 比较(endswith)
   */
  private Long lastUpdateUserEndswith;
  /**
   * 更新人 比较(isnull)
   */
  private Boolean lastUpdateUserIsnull;
  /**
   * 更新人 比较(isnotnull)
   */
  private Boolean lastUpdateUserIsnotnull;

  /**
   * 产品
   */
  private Long productId;

  /**
   * 产品 比较(eq)
   */
  private Long productIdEq;
  /**
   * 产品 比较(neq)
   */
  private Long productIdNeq;
  /**
   * 产品 比较(gt)
   */
  private Long productIdGt;
  /**
   * 产品 比较(gte)
   */
  private Long productIdGte;
  /**
   * 产品 比较(lt)
   */
  private Long productIdLt;
  /**
   * 产品 比较(lte)
   */
  private Long productIdLte;
  /**
   * 产品 比较(contains)
   */
  private Long productIdContains;
  /**
   * 产品 比较(notcontains)
   */
  private Long productIdNotcontains;
  /**
   * 产品 比较(startswith)
   */
  private Long productIdStartswith;
  /**
   * 产品 比较(endswith)
   */
  private Long productIdEndswith;
  /**
   * 产品 比较(isnull)
   */
  private Boolean productIdIsnull;
  /**
   * 产品 比较(isnotnull)
   */
  private Boolean productIdIsnotnull;
  /**
   * 产品的品名 比较(eq)
   */
  private String productIdNameEq;
  /**
   * 产品的品名 比较(neq)
   */
  private String productIdNameNeq;
  /**
   * 产品的品名 比较(gt)
   */
  private String productIdNameGt;
  /**
   * 产品的品名 比较(gte)
   */
  private String productIdNameGte;
  /**
   * 产品的品名 比较(lt)
   */
  private String productIdNameLt;
  /**
   * 产品的品名 比较(lte)
   */
  private String productIdNameLte;
  /**
   * 产品的品名 比较(contains)
   */
  private String productIdNameContains;
  /**
   * 产品的品名 比较(notcontains)
   */
  private String productIdNameNotcontains;
  /**
   * 产品的品名 比较(startswith)
   */
  private String productIdNameStartswith;
  /**
   * 产品的品名 比较(endswith)
   */
  private String productIdNameEndswith;
  /**
   * 产品的品名 比较(isnull)
   */
  private Boolean productIdNameIsnull;
  /**
   * 产品的品名 比较(isnotnull)
   */
  private Boolean productIdNameIsnotnull;

  /**
   * 产品(范围搜索)
   */
  private List<Long> productIdInList;

  /**
   * 配对类型
   */
  private String type;

  /**
   * 配对类型 比较(eq)
   */
  private String typeEq;
  /**
   * 配对类型 比较(neq)
   */
  private String typeNeq;
  /**
   * 配对类型 比较(gt)
   */
  private String typeGt;
  /**
   * 配对类型 比较(gte)
   */
  private String typeGte;
  /**
   * 配对类型 比较(lt)
   */
  private String typeLt;
  /**
   * 配对类型 比较(lte)
   */
  private String typeLte;
  /**
   * 配对类型 比较(contains)
   */
  private String typeContains;
  /**
   * 配对类型 比较(notcontains)
   */
  private String typeNotcontains;
  /**
   * 配对类型 比较(startswith)
   */
  private String typeStartswith;
  /**
   * 配对类型 比较(endswith)
   */
  private String typeEndswith;
  /**
   * 配对类型 比较(isnull)
   */
  private Boolean typeIsnull;
  /**
   * 配对类型 比较(isnotnull)
   */
  private Boolean typeIsnotnull;

  /**
   * 配对类型(精确搜索)
   */
  private List<String> typeInList;

  /**
   * SKUID(模糊搜索)
   */
  private String skuId;

  /**
   * SKUID 比较(eq)
   */
  private String skuIdEq;
  /**
   * SKUID 比较(neq)
   */
  private String skuIdNeq;
  /**
   * SKUID 比较(gt)
   */
  private String skuIdGt;
  /**
   * SKUID 比较(gte)
   */
  private String skuIdGte;
  /**
   * SKUID 比较(lt)
   */
  private String skuIdLt;
  /**
   * SKUID 比较(lte)
   */
  private String skuIdLte;
  /**
   * SKUID 比较(contains)
   */
  private String skuIdContains;
  /**
   * SKUID 比较(notcontains)
   */
  private String skuIdNotcontains;
  /**
   * SKUID 比较(startswith)
   */
  private String skuIdStartswith;
  /**
   * SKUID 比较(endswith)
   */
  private String skuIdEndswith;
  /**
   * SKUID 比较(isnull)
   */
  private Boolean skuIdIsnull;
  /**
   * SKUID 比较(isnotnull)
   */
  private Boolean skuIdIsnotnull;

  /**
   * SKUID(精确搜索)
   */
  private List<String> skuIdInList;

  /**
   * 表单名称
   */
  private String formName;

  /**
   * 工作流状态
   */
  private Integer wfStatus;
}
